package 排序;

import java.util.Arrays;

public class ShellSort {
	public static void main(String[] args) {
		int[] arr = {8,9,1,7,2,3,5,4,6,0};
		shellSort(arr);
		System.out.println(Arrays.toString(arr));
	}
	
	public static void shellSort(int[] arr) {
		if(arr == null || arr.length == 0) return;
		int temp = 0;
		for(int gap = arr.length/2; gap > 0; gap /= 2) {
			for(int i = gap; i < arr.length; i++) {
				for(int j = i -gap; j >= 0; j -= gap) {
					if(arr[j] > arr[j+gap]) {
						temp = arr[j];
						arr[j] = arr[j+gap];
						arr[j+gap] = temp;
					}
				}
			}
		}
	}
	
	
	
	
	
	
	
//	public static void shellSort(int[] arr) {
//		for(int gap = arr.length /2; gap > 0; gap /= 2) {
//			int temp = 0;
//			for(int i = gap; i < arr.length; i++) {
//				for(int j = i - gap; j >= 0; j -= gap) {
//					if(arr[j] > arr[j+gap]) {
//						temp = arr[j];
//						arr[j] = arr[j+gap];
//						arr[j+gap] = temp;
//					}
//				}
//			}
//		}
//	}
	
	
	
	
	
	
	
	
	
	
	
	
//	public static void shellSort(int[] arr) {
//		int temp = 0;
//		int count = 0;
//		
//		for(int gap = arr.length / 2; gap > 0; gap /= 2) {
//			for(int i = gap; i < arr.length; i++) {
//				for(int j = i - gap; j >= 0; j -= gap) {
//					if(arr[j] > arr[j + gap]) {
//						temp = arr[j];
//						arr[j] = arr[j+gap];
//						arr[j+gap] = temp;
//					}
//				}				
//			}
//			System.out.println("第"+(++count)+"轮后 arr = "+Arrays.toString(arr));
//		}
//	}
}
